Skip to main content

Delete Chat Endpoint

Overview

This endpoint deletes a specific chat conversation for a user.

Request Details

HTTP Method

DELETE

Route

/api/users/[user_id]/chats/[chat_id]

Route Parameters

ParameterTypeRequiredDescription
user_idintegerYesUnique identifier of the user
chat_idintegerYesUnique identifier of the chat to delete

Headers

HeaderValueRequiredDescription
Cookieneptun-sessionYesSession authentication cookie

Query Parameters

No query parameters required.

Request Body

No request body required.

Response Format

Response Status Codes

Status CodeDescription
200Chat successfully deleted
401Unauthorized (invalid or missing session)
404Chat or user not found
500Server error during deletion

Success Response (200 OK)

Returns a boolean indicating whether the deletion was successful.

true

Error Response (404 Not Found)

{
"statusCode": 404,
"statusMessage": "Not Found",
"data": {
"message": "Chat not found"
}
}

TypeScript Interface

interface DeleteChatResponse {
success: boolean
}

interface DeleteChatError {
statusCode: number
statusMessage: string
data: {
message: string
}
}

Python Model

from pydantic import BaseModel

class DeleteChatResponse(BaseModel):
success: bool

class ErrorData(BaseModel):
message: str

class DeleteChatError(BaseModel):
statusCode: int
statusMessage: str
data: ErrorData

Code Examples

Python Example

from pydantic import BaseModel
import httpx

class DeleteChatResponse(BaseModel):
success: bool

async def delete_chat(
user_id: int,
chat_id: int,
session_cookie: str
) -> bool:
async with httpx.AsyncClient() as client:
response = await client.delete(
f"https://neptun-webui.vercel.app/api/users/{user_id}/chats/{chat_id}",
cookies={"neptun-session": session_cookie}
)
response.raise_for_status()
return response.json()

cURL Example

curl -X DELETE \
-H "Cookie: neptun-session=your-session-cookie" \
"https://neptun-webui.vercel.app/api/users/your-user-id/chats/123"

TypeScript/JavaScript Example

async function deleteChat(
userId: number,
chatId: number
): Promise<boolean> {
const response = await fetch(
`https://neptun-webui.vercel.app/api/users/${userId}/chats/${chatId}`,
{
method: 'DELETE',
credentials: 'include', // Important for cookie handling
}
)

if (!response.ok) {
throw new Error(`HTTP error! status: ${response.status}`)
}

return await response.json()
}

Notes

  • The session cookie is required for authentication
  • The chat must belong to the specified user
  • This operation cannot be undone
  • All associated chat messages will also be deleted